oracle

推荐列表 站点导航

当前位置:首页 > 数据库 > oracle >

oracle中length、lengthb、substr、substrb函数用法介绍

来源:互联网  作者:网友投稿  发布时间:2021-01-06 07:45
这篇文章主要介绍了oracle中length、lengthb、substr、substrb函数用法的相关内容,具有一定参考价值,需要的朋友可以参考...

我记得我曾经在开发form的时候犯过这样一个错误,对于form中的某个字段,对应于数据库中某张表的字段,假设在数据库中这个字段一般也就用到20个汉字的长度,后来我在开发form的时候,设置item类型长度的时候,我惯性的设置成了50byte,想着就算是20个汉字,最多也就占40个byte长度嘛。可是,就因为这一个想当然,结果出现错误了,后来发现数据库字符集编码是utf8,那么应该设置为60。从那以后,每次涉及到给字段设置长度的时候,我都会特别注意下,到底是啥编码。

在oracle中,比较常见的可能是length、substr,至少我看到的大部分都是这两个,要不是昨天看代码发现了lengthb、substrb,估计我也遗忘了。length表示的是字符串的字符长度,lengthb表示的是字符串的字节长度;substr表示根据字符长度获取子串,substrb表示根据字节长度来获取字串。下面直接看例子来说明:

?

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

 

SELECT length('叶德华abc') -- length按字符计,汉字、英文、数字都是1个字符,故这里返回6

 FROM dual;

SELECT lengthb('叶德华abc') -- length按字节计,我这里是UTF-8编码,汉字3个字节,英文一个字节,故这里返回12

 FROM dual;

SELECT substr('叶德华abc', -- substr按字符截取,截取到a,返回:叶德华a

       1,

       4)

 FROM dual;

SELECT substrb('叶德华abc',

        1,

        2) -- substrb按字节截取,2不足一个汉字长度,返回:两个空格

 FROM dual;

SELECT substrb('叶德华abc',

        1,

        3) -- substrb按字节截取,3刚好是一个汉字长度,返回:叶

 FROM dual;

SELECT substrb('叶德华abc',

        1,

        4) -- substrb按字节截取,4多余一个汉字少于两个汉字,返回:叶 加一个空格

 FROM dual;

 

在oracle中应该还有其他类似的方法,这里就不总结了,大概就是这么个意思。补充一下,据说在oracle中定义字符类型的时候默认的长度是byte,比如varchar2(20)表示的是20个字节长度,如果要定义成字符,则varchar2(20 char),不过,一般我们也都用字节定义。

相关热词:

本站内容来源于网络,如有侵权请与我们联系,我们会及时删除,我们深感抱歉!
注:本站所有信息仅供用于网络技术学习参考,学习中请遵循相关法律法规!

本文地址: https://v30.fanwenzhu.com/sql/oracle/11387.shtml

Copyright © www.juheyunku.com      关于 | 合作 | 声明 | 联系 | 更新 | 地图 | Tags

oracle中length、lengthb、substr、substrb函数用法介绍

2021-01-06 编辑:网友投稿

我记得我曾经在开发form的时候犯过这样一个错误,对于form中的某个字段,对应于数据库中某张表的字段,假设在数据库中这个字段一般也就用到20个汉字的长度,后来我在开发form的时候,设置item类型长度的时候,我惯性的设置成了50byte,想着就算是20个汉字,最多也就占40个byte长度嘛。可是,就因为这一个想当然,结果出现错误了,后来发现数据库字符集编码是utf8,那么应该设置为60。从那以后,每次涉及到给字段设置长度的时候,我都会特别注意下,到底是啥编码。

在oracle中,比较常见的可能是length、substr,至少我看到的大部分都是这两个,要不是昨天看代码发现了lengthb、substrb,估计我也遗忘了。length表示的是字符串的字符长度,lengthb表示的是字符串的字节长度;substr表示根据字符长度获取子串,substrb表示根据字节长度来获取字串。下面直接看例子来说明:

?

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

 

SELECT length('叶德华abc') -- length按字符计,汉字、英文、数字都是1个字符,故这里返回6

 FROM dual;

SELECT lengthb('叶德华abc') -- length按字节计,我这里是UTF-8编码,汉字3个字节,英文一个字节,故这里返回12

 FROM dual;

SELECT substr('叶德华abc', -- substr按字符截取,截取到a,返回:叶德华a

       1,

       4)

 FROM dual;

SELECT substrb('叶德华abc',

        1,

        2) -- substrb按字节截取,2不足一个汉字长度,返回:两个空格

 FROM dual;

SELECT substrb('叶德华abc',

        1,

        3) -- substrb按字节截取,3刚好是一个汉字长度,返回:叶

 FROM dual;

SELECT substrb('叶德华abc',

        1,

        4) -- substrb按字节截取,4多余一个汉字少于两个汉字,返回:叶 加一个空格

 FROM dual;

 

在oracle中应该还有其他类似的方法,这里就不总结了,大概就是这么个意思。补充一下,据说在oracle中定义字符类型的时候默认的长度是byte,比如varchar2(20)表示的是20个字节长度,如果要定义成字符,则varchar2(20 char),不过,一般我们也都用字节定义。

本站内容来源于网络,如有侵权请与我们联系,我们会及时删除,我们深感抱歉!
注:本站所有信息仅供学习参考!
本文地址为 https://v30.fanwenzhu.com/sql/oracle/11387.shtml

相关文章

风云图片

推荐阅读

返回oracle频道首页